<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>canvas-demos</title>

    <style>
        canvas {
            margin: 0 auto;
            border: 2px solid #aaa;
            display: block;
        }
    </style>
</head>

<body>
<canvas id="cont" width="500px" height="500px">浏览器不支持</canvas>
<!--只能使用原生的js,如果让canvas左右居中使用display:block-->
<script>
    // 固定start获取画布
    const canvas = document.querySelector('#cont')
    // 获取画布上下文
    const ctx = canvas.getContext('2d')
    // 固定end

    // 起点(100,100) 长宽300 200 普通矩形:既可以描边也可以填充
    ctx.rect(100, 100, 300, 200)
    // 先填充
    ctx.fillStyle = 'green'
    ctx.fill()
    // 后描边
    ctx.strokeStyle = 'red'
    ctx.lineWidth = 4
    ctx.stroke()

    // fillRect绘制实心
    ctx.fillStyle = 'pink'
    ctx.fillRect(100, 350, 100, 100)

    // stroke绘制空心矩形
    ctx.strokeStyle = 'gold'
    ctx.lineWidth = 2
    ctx.strokeRect(300, 350, 100, 100)

</script>
</body>
</html>
